home *** CD-ROM | disk | FTP | other *** search
/ Gold Medal Software 1 / Gold Medal Software Volume 1 (Gold Medal) (1994).iso / prog / dfqbx30.arj / HISTORY.TXT < prev    next >
Encoding:
Text File  |  1993-07-19  |  35.3 KB  |  796 lines

  1.  
  2.                    HISTORY FILE FOR DOORFRAMEX (BASCOM 7.X)
  3.                    ========================================
  4.   
  5.   NOTE: Ted Freeman died on July 13, 1993 and had asked that I continue 
  6.         his programs which I will do with the assistance of Chuck Valecek.
  7.         The support bbs will now be The Livewire BBS 609-235-5297 USR HST.
  8.  
  9.                         Richard Paquette
  10.  
  11. Version 3.0
  12. -----------
  13. (06-28-93)
  14.   Well, looks like DoorFrame has finally grown to big for it's britches!
  15.  Wondered how long it would take with all the new stuff I've been adding.
  16.  Have had reports of String Space Corrupt errors which means it's time to
  17.  trim it down a bit. Consequently I had to decide what to discard. It was
  18.  a hard decision but I decided to drop support for WWIV's CHAIN.TXT file.
  19.  This will probably upset a few people but I tried to pick something that
  20.  would affect the least amount of systems.
  21.  Again, DOORFRAME NO LONGER SUPPORTS WWIV AND CHAIN.TXT.
  22.  
  23. (06-25-93)
  24.   Changed the way ENTER operates. Previously, it would accept any keystroke
  25.  and go on it's merry way. It now must actually receive an Enter key. This
  26.  change was made mainly for PCBoard/M. Although DoorFrame works flawlessly
  27.  with the vast majority of the systems running the M version, I have had a
  28.  couple of reports that on a few systems they are still getting 4 or 5
  29.  random characters at the start of the door. By using the ENTER subroutine
  30.  at the bottom of your opening screen, it should catch any extraneous
  31.  characters that should happen to pop up at the beginning (up to 80).
  32.  
  33.   Added another variable (like we NEED another one!). Check4RIP% lets you
  34.  the programmer decide if you want to check for RIPscrip compatibility.
  35.  Obviously if your door doesn't send RIPscrip codes, you could care less
  36.  if the remote is RIP compatible or not. The default for Check4RIP% is 0
  37.  which does not check. If you do want to check for RIPscrip, populate the
  38.  variable with a non-zero value. You must assign this variable before calling
  39.  Detect.Ansi.
  40.  
  41. Version 2.9
  42. -----------
  43. (06-17-93)  
  44.   DoorFrame will now recognize RIPscrip! There are two new variables
  45.  available, Rip% and Rip$. Rip% will be 0 if RIPscrip was not detected and
  46.  1 if it was. Rip$ will contain the RIPscrip version number in the format
  47.  RIPSCRIPxxyyzz where xx = major version number, yy = minor version number
  48.  and zz = revision code. For example if the version number is v1.52.00 
  49.  Rip$ would contain RIPSCRIP015200.
  50.   The Graphics% variable is not adjusted in response to the presence or 
  51.  absence of RIPscrip.
  52.  
  53. Version 2.8
  54. -----------
  55. (06-13-93)
  56.   Finally got this sucker to work with the PCBoard/M version! Although I
  57.  have no way of testing, it should also work with the Wildcat! IM software.
  58.  Maybe some of you Wildcatters can shoot me some feedback on whether it
  59.  does or not.
  60.   There is a trade-off involved (naturally!).  I still can't figure out
  61.  where the *'s are coming from so the only solution I could come up with was
  62.  to ignore any *'s. So if you have any In.Put statements that require an *
  63.  as a response, you will have to change it. This only applies when the /FD
  64.  (fossil driver) parameter is being used. When no fossil is being used, the
  65.  * is accepted like always.
  66.  
  67. Version 2.7
  68. -----------
  69. (04-21-93)
  70.   Added the RIP color switch for Wildcat! systems. Color is now displayed if
  71.  either GR or RIP is detected in the Wildcat! DOOR.SYS file.
  72.  
  73. (04-20-93)
  74.   When adding the addtional colors for the shadow in the Box.It routine, I
  75.  neglected to allow for Black as a color! Therefore, 0 now indicates a Black
  76.  shadow and -1 indicates no shadow is to be used.
  77.  
  78. (04-18-93)
  79.   Added the Cipher routines from the PBClone library. These two routines
  80.   (Cipher and CipherP) allow simple text encryption/decryption with password
  81.   protection. Check the PBC-SUBS.DOC file for instructions on their use.
  82.  
  83. (04-16-93)
  84.   Added the ClearBuffer routine. This routine allows you to clear either
  85.  the keyboard buffer, the communications input buffer, or both. Parameters 
  86.  are: 0 = Clear both, 1 = Clear comm. input only, 2 = Clear keyboard only.
  87.  
  88. (04-13-93)
  89.   Added another parameter to the SendAnsi routine. The third parameter is
  90.  Inter% and indicates whether or not to disable the ability to interrupt
  91.  the ANSI file with the spacebar as it is displaying. 0 = Don't disable, 
  92.  1 = Disable. The default is 0.
  93.  
  94. (03-29-93)
  95.   Added support for PCBoard v15.0 Alias name. I added this because the
  96.  ALIAS$ variable was already in DoorFrame. I will not be adding the rest of
  97.  the new stuff from v15.0 as that would needlessly inflate the size of the
  98.  library to support only one system. (so don't ask!)
  99.  
  100. Version 2.6
  101. -----------
  102. (03-25-93)
  103.   Well my tweaking of the DETECT.ANSI routine didn't work quite the way it
  104.  was intended to! Consequently it is back to the way it was before.
  105.  
  106. (03-24-93)
  107.   When using the Box.It routine, you may now specify a background color to
  108.  be used for the Shadow% parameter. 0 = No Shadow, 1 - 7 = Background Color
  109.  for the Shadow.
  110.  
  111. (03-20-93)
  112.   Fixed a problem with clearing the screen on the local display when in 
  113.  ASCII only mode.
  114.  
  115. (03-14-93)
  116.   Tweaked the DETECT.ANSI routine a bit. Hopefully it will do away with
  117.  those non-ANSI messages when ANSI is actually there!
  118.  
  119. Version 2.5
  120. -----------
  121. (02-25-93)
  122.   Well of course I had to screw something up when expanding the COM port
  123.  range! This only affected the DORINFOx.DEF systems but any COM port above
  124.  one got changed back to 1 which would usually result in a carrier lost
  125.  message.
  126.  
  127. (02-09-93)
  128.   Finally got around to expanding the COM port range. DoorFrame now supports
  129.  COM 0 thru 15.
  130.  
  131. Version 2.4
  132. -----------
  133. (01-12-93)
  134.   Silly me! When checking for the fossil driver parameter I neglected to put
  135.  the / in there. So it was checking for FD instead of /FD. That means if your
  136.  .CFG filename contained those 2 letters (as in dFDdemo!), it would pick that
  137.  up as the fossil parameter. Corrected now.
  138.  
  139. (01-07-93)
  140.   That old problem with the time expired when the Display was toggled off
  141.  in PCBoard popped up again! Fixed one more time (gotta quit changing things).
  142.  
  143. (01-03-93)
  144.   Removed the CLRSCRN during the INTIALIZE process so now clearing the
  145.  screen is up to you at the beginning of the door.
  146.  
  147. (12-23-92)
  148.   Fixed a stupid error on my part in the SENDANSI routine. I was opening the
  149.  file as FIL but was closing FILE! So the open file handles would just stack
  150.  up everytime the routine was called.
  151.  
  152. (12-12-92)
  153.   Added a new routine called SendAnsi. This routine is for true ANSI files
  154.  only! It sends the entire file non-stop. Pressing the Spacebar aborts the
  155.  file send. See the .DOC file for an explanation of accepted parameters.
  156.  
  157. Version 2.3
  158. -----------
  159. (11-24-92)
  160.   Noticed that I had only allowed for a single digit when specifying a
  161.  non-standard IRQ. That has been changed to accept 2 digits.
  162.  
  163. (11-19-92)
  164.   DoorFrame will now recognize the %pcbnode% and %wcnodeid% environment
  165.  variables when reading the path to the system file (1st line of the .CFG).
  166.  Some examples:
  167.     PCBoard: If USERS.SYS is located in C:\PCB\NODE1 directory, 
  168.        %pcbdrive%%pcbdir%\NODE%pcbnode%\USERS.SYS
  169.     Wildcat!: USERINFO.DAT located in C:\WC\NODE3 directory,
  170.        C:\WC\NODE%wcnodeid%\USERINFO.DAT
  171.     or if you SET the %pcbdrive% and %pcbdir% variables via the batch,
  172.        %pcbdrive%%pcbdir%\NODE%wcnodeid%\USERINFO.DAT
  173.  
  174. (11-15-92)
  175.   Changed the code so that USERINFO.DAT is written automatically. Therefore
  176.  you no longer need to use the User.Info% variable. Also took the routine
  177.  out that writes DOOR.SYS when using USERINFO.DAT. Since WildCat! doesn't
  178.  read it back in, that was sorta useless. (Thanks Dennis!)
  179.  
  180. (11-01-92)
  181.   DoorFrame now includes support for FOSSIL drivers!!! This means your Doors
  182.  will work with most multi-port boards. To activate the Fossil driver 
  183.  support, just include /FD on the command line when running the Door. 
  184.  For example: MYDOOR MYDOOR.CFG /FD
  185.  If no Fossil driver is available, DoorFrame will display a message to that
  186.  effect and exit gracefully.
  187.  
  188. (10-24-92)
  189.   Some of you may have noticed a slow down in the Dis.Play command after the
  190.  color codes were added (~, `, @, ^, |, {, and }). Dis.Play now has an 
  191.  additional parameter (Codes%) that let's you specify whether or not you 
  192.  are using the color codes. If a particular Dis.Play statement doesn't use
  193.  the codes, place a 0 in the Codes% parameter and the routine that checks
  194.  for and strips those characters will be bypassed. Thus significantly
  195.  increasing the display speed.
  196.  
  197. (10-23-92)
  198.   Added 2 more parameters to the In.Put command. These new parameters allow
  199.  you to specify a different color if you populate the Text$ parameter. Refer
  200.  to the docs for a full explanation.
  201.  
  202. Version 2.2
  203. -----------
  204. (10-19-92)
  205.   Well, should have known I would screw something up! Sure enough I did on
  206.  the LastOn$ variable. In the USERS file, it is in the format YYMMDD and 
  207.  is converted to the MM-DD-YY format when read. I neglected to convert it
  208.  back when writing to the USERS file.
  209.  
  210. (10-18-92)
  211.   Would you believe ... all this time DoorFrame has been reading info from
  212.  the PCBoard USERS file but hasn't been writing it! Actually, this would 
  213.  only affect a few of the variables. Anyway, that oversight has been
  214.  corrected. (Thanks Peter!)
  215.  
  216. (10-10-92)
  217.   Had reports of conflicts when using non-standard IRQ's on Novell/Netware
  218.  systems. Seems Novell also uses the / character so something went screwy
  219.  somewhere. So I added the * (asterisk) which may be used instead of the /
  220.  in case of a conflict. In other words, /%IRQ% and *%IRQ% will both work
  221.  and are interchangeable.
  222.  
  223. (09-23-92)
  224.   Fixed a bug when restoring the screen after Chat or Drop to DOS. It would
  225.  generate an illegal function call whenever it hit a blinking character.
  226.  
  227. (09-22-92)  
  228.   You now have the option of taking control after a carrier loss in case you
  229.  need to do some clean-up before recycling back to the BBS. BE VERY CAREFUL
  230.  with this one! Check the Docs under Miscellaneous Notes for an explanation.
  231.  
  232. Version 2.1
  233. -----------
  234. (09-20-92)
  235.    Fixed a problem when using the new no-show option of In.Put. If you used
  236.   a Dis.Play statement with color codes immediately after that, it would
  237.   show the color codes rather than the color.
  238.  
  239. (09-14-92)
  240.   The In.Put command now features word-wrap ability! If you put, for example,
  241.  160 as the first parameter, it will wrap around at the nearest space when it
  242.  reaches column 80 on the screen. Backspacing also works over the word-wrap.
  243.  
  244.   DoorFrame will now handle the 30-something line DOOR.SYS file as well as 
  245.  the 52-line one.
  246.  
  247.   Corrected some errors in writing the SFDOORS.DAT file. Specifically the
  248.  COMPORT% and DAILY.BYTES.ALWD& variables.
  249.  
  250. (09-13-92)
  251.   Added 5 new parameters to the In.Put command. 
  252.       AutoCR% - Automatic Carriage Return. 0 = No, 1 = Yes
  253.       Text$   - Text to display (if any).
  254.       Xpos%   - X coordinate to print Text$
  255.       Ypos%   - Y coordinate to print Text$
  256.       Show%   - 0 = Don't display response, 1 = display response
  257.  For example:
  258.  
  259.     In.Put 5, 0, 11, 0, 0, "", 0, 0, 1
  260.  
  261.  would accept 5 characters but would not return until the user hits the
  262.  ENTER key. Conversely,
  263.  
  264.     In.Put 5, 0, 11, 0, 1, "Well? ", 20, 1, 1
  265.  
  266.  would accept 5 characters and automatically return from the routine. It will
  267.  also print 'Well? ' at location 20, 1 and the response would be displayed.
  268.  If you wanted a Hot Key and didn't want the response to show:
  269.  
  270.     In.Put 1, 0, 11, 0, 1, "Y/N ", 20, 1, 0
  271.  
  272.  would prompt for 'Y/N' but would not display the response. The variable
  273.  Response$ will still contain whatever was typed even though it didn't show
  274.  up on the screen.
  275.  
  276. (09-11-92)  
  277.   Finally installed the screen restore when coming back from Chat or a Drop
  278.  to Dos. Been wanting to do that for months now! It will now put the screen
  279.  back like it was including anything typed at an In.Put prompt. If the caller
  280.  had entered anything before the interruption, that is restored and he can
  281.  pick up right where he left off!
  282.  
  283. Version 2.0
  284. -----------
  285. (09-06-92)
  286.   Had a request to be able to turn off the Status lines at the bottom of the
  287.  screen so that has been installed. To blank out those 2 lines, set the
  288.  variable No.Status% = 1 and do a ClrScrn. Sorry but those 2 lines are still
  289.  not available for printing (that would mean changing half the routines in
  290.  DoorFrame!).
  291.  
  292. (09-05-92)
  293.   Fixed an intermittent problem with the cursor jumping to the top left of
  294.  the screen when backspacing.
  295.  
  296. (09-04-92)
  297.   Did some more code optimizing. The same door used below in v1.9 now compiles
  298.  to 106,610 for an additional reduction of 6K in the .EXE!
  299.  
  300.   You should also notice a tremendous increase in the display speed. Using
  301.  a test program that printed 18 lines and contained the color codes around
  302.  each word, it took 30.92 seconds for v1.9 to finish. Version 2.0 did it in
  303.  8.95 seconds. That's a speed increase of over 345%!
  304.  
  305.   Added 2 new routines to the library. ClrMol clears in the middle of a line
  306.  for the number of specified columns. ClrSol clears from the specified X, Y
  307.  coordinates to the start of that line.
  308.  
  309. (09-03-92)
  310.   Re-paged the docs to a maximum of 60 lines per page for laser printers.
  311.  
  312. Version 1.9
  313. -----------
  314. (08-27-92)
  315.   Did some more optimizing of the code so your .EXE files should be a bit
  316.  smaller than with v1.8.  One of my doors compiled to 114,288 with v1.8 and
  317.  112,754 with v1.9, so it knocked almost 2K off the final .EXE!
  318.  
  319.   Fixed a problem which, in certain instances, would generate a 'Time
  320.  Expired' message when the local display was toggled off (F9).
  321.  
  322. (08-24-92)
  323.   Added a bunch more routines from Hanlin's PBClone library. I'll leave you
  324.  the fun of discovering which ones. <G>
  325.  
  326.   Deleted the BIOSINKEY and KEYPRESS routines since they are local keyboard
  327.  only routines.
  328.  
  329. Version 1.8
  330. -----------
  331. (06-21-92)
  332.   Added support for TriBBS software. DoorFrame both reads and writes the
  333.  TRIBBS.SYS file.
  334.  
  335. (06-15-92)
  336.   Added a new Back.Space routine. Syntax is: Back.Space Row%, Col%, Num%
  337.  Give it the row, column, and number of backspaces, the cursor will be
  338.  positioned at the last backspace so if the Col% = 20 and Num% = 5, the
  339.  cursor is left at column 16 (columns 20, 19, 18, 17, and 16 are erased).
  340.  
  341. Version 1.7
  342. -----------
  343. (06-03-92)
  344.   Fixed an oversight dealing with the TimeAdjust% variable. The problem wasn't
  345.  with the variable itself but rather with the frequency of updating the Status
  346.  line (which was every 30 seconds). Now it will update after each Dis.Play
  347.  statement. So if you are adjusting the callers time right before leaving the
  348.  door, just Dis.Play a space or something immediately after using TimeAdjust%.
  349.  
  350. (05-24-92)
  351.   Added the 'Last New Files Date' variable for those systems using Wildcat!'s
  352.  USERINFO.DAT. The variable name is LastScan$
  353.  
  354. (05-20-92)
  355.   Finally added a feature that has been sorely needed. You may now run your
  356.  doors from the DOS command line. Syntax is MYDOOR LOCAL. DoorFrame will plug
  357.  in enough dummy variables to enable it to run without using a BBS file.
  358.  Since the .CFG file will not be opened when using LOCAL, you should bypass 
  359.  any access to the .CFG file. If you MUST read additional lines from the .CFG
  360.  then I would suggest not using the LOCAL option.
  361.  
  362. (05-12-92)
  363.   Fixed a bug in the In.Put routine. Seems that the ASCII (or extended) SHIFT
  364.  code for H, K, M, and P are the same as the scan codes for the arrows! So it
  365.  was interpreting those 4 letters as arrow codes instead of the correct letter
  366.  codes. The routine now checks the value of SysopKeys% to determine if it is
  367.  a letter or an arrow. If SysopKeys% = 0, it's a letter, if SysopKeys% = 1,
  368.  it's an arrow. This means you must only set SysopKeys% = 1 when you want to
  369.  use the arrow keys since those 4 letters will also be interpreted as arrow
  370.  keys. If you are expecting alphabetic input, you will get some strange
  371.  results!
  372.  
  373. (05-11-92)
  374.   Thought I had fixed it so no beeps were heard on the local but not so. It
  375.  is fixed now, fer sure, fer sure!
  376.  
  377. (05-09-92)
  378.   Learned what the Extra Time field was for in SFDOORS.DAT (thanks Chuck).
  379.  Now if you utilize the TimeAdjust% variable, the Extra Time field in 
  380.  SFDOORS.DAT will be adjusted up or down accordingly.
  381.  
  382.   Found out that Wildcat! looks for an Error Level of 1 when recycling so
  383.  DoorFrame now generates a DOS error level of 1 when running under Wildcat!
  384.  systems and error level 62 for all others (for now!).
  385.  
  386. (05-05-92)
  387.   DoorFrame will now generate a DOS error level of 62. I understand that
  388.  GAP systems can use this to correctly recycle the BBS whenever someone logs
  389.  off from inside a door. Need some feedback on other systems please. 
  390.  
  391.   Added a couple of needed variables that were omitted when writing the
  392.  PCBoard USERS.SYS file. The descrepancy would only show up when logging
  393.  off from within a door but the time used and last date on were not being
  394.  updated.
  395.  
  396. (05-02-92)
  397.   Think I finally came up with a workable solution to get rid of the TIMER
  398.  routines which drives a math coprocessor up the wall. The trade-off is that
  399.  the status line will only be updated whenever input is required from the
  400.  caller.
  401.  
  402. Version 1.6
  403. -----------
  404. (04-29-92)
  405.   Included with this version is the .BAS source for a door called DFDEMO. It
  406.  demonstrates some of the features of DoorFrame.  You may also want to use
  407.  it to pick up some tips on using some of the routines.  The EXINPUT.BAS and
  408.  DISPLAY.BAS files have been removed.
  409.  
  410. (04-27-92)
  411.    Took me a whole day's work, but I dood it!  You may now use the color
  412.  codes as often as you wish when Dis.Playing a line. In addition the colors
  413.  and blinking are each independent of each other, so you can blink one, some,
  414.  all, or none! The % turns on the blinking for each set of codes.
  415.  
  416.   Added a parameter to the ClrScrn routine. You may now clear the local and
  417.  remote screen in any background color you wish (0 - 7).
  418.  
  419.   Did a bit more optimizing of the code and even with the new stuff added,
  420.  was able to reduce the size of .LIB by almost 3K!   
  421.  
  422. (04-24-92)
  423.   In an effort to cut down on the number of variables we have to deal with
  424.  (and hopefully cut down on memory requirements), I have combined the various
  425.  system variables (Pcboard%, WildCat%, etc.) into one. System.File% will take
  426.  their place. The value of System.File% will tell you which BBS file is being
  427.  used according to the following values:
  428.      1 = PCBOARD.SYS            2 = USERS.SYS           3 = DOOR.SYS
  429.      4 = CALLINFO.BBS           5 = CHAIN.TXT           6 = DORINFOx.DEF
  430.      7 = SFDOORS.DAT            8 = USERINFO.DAT        9 = GTUSER.BBS
  431.  
  432.   Deleted the Num.Dl.Today% variable. Use DlToday& instead.
  433.  
  434. (04-23-92)
  435.   Have been receiving reports of an Error 6 (overflow) when using DoorFrame
  436.  doors with the latest version of Spitfire.  Have been trying to locate an
  437.  actual SFDOORS.DAT file. Finally one of my users uploaded one to me (thanks
  438.  Aldo!). Lo and behold in the Downloads Per Day field there was 54,730! 
  439.  So to stave off any more problems like this, I have changed the DlPerDay%,
  440.  DlToday%, Downloads%, and Uploads% from INTEGER to LONG INTEGER.
  441.  
  442.   Used that extra space from the ON KEY and added support for GT Power's
  443.  GTUSER.BBS file. The .CFG file for this one is a little different.  Since
  444.  the file doesn't provide the COM port or Node numbers, they must be added on
  445.  lines 5 and 6 of the .CFG file.
  446.  
  447. (04-22-92)
  448.   Been reading how the ON KEY statement adds a lot of overhead to QB programs
  449.  so have been researching how to get rid of them. Lo and behold, I found this
  450.  neat little routine to do just that!  So all the ON KEY (and the associated
  451.  KEY statements) are gone.  This change also knocked almost 2K off the size
  452.  of the library.
  453.  
  454. Version 1.5
  455. -----------
  456. (04-20-92)
  457.    Added the PCBoard Language extension parameter, LANGUAGE$, at the request
  458.  of one of our European users. (Thanks Peter!) This variable will contain the
  459.  extension of the language file, i.e.  .FRE for the French language. When
  460.  using the default language (whichever one that is), this variable will
  461.  contain 4 spaces.
  462.  
  463. (04-17-92)
  464.   Added two new parameters to the BOX.IT routine. HFG% and HBG% now let's
  465.  you specify the foreground and background colors when using a Title$ on
  466.  your boxes.  Also added a check to see if Title$ is longer than the box.
  467.  This would generate an Illegal Function error previously. Your Title$ must
  468.  be at least 6 characters less than the width of the box. If it is longer
  469.  than that, the routine simply ignores the Title$.
  470.  
  471. Version 1.4
  472. -----------
  473. (04-10-92)
  474.   Made some small changes in reading the PCBoard USERS file (nothing major).
  475.  Noticed that the callers first name variable was missing from DOOR.SYS,
  476.  USERINFO.DAT etc. so those have been added.
  477.  
  478. (04-04-92)
  479.   Fixed a small error in the SEND command when displaying an ASCII file.
  480.  Seems it was reading from one file number and looking for the end of 
  481.  another which would either not display all the file or generate an INPUT
  482.  PAST END error.
  483.  
  484. (03-21-92)
  485.   DoorFrame doors may now make use of the IRQ environment variable. For
  486.  example, instead of DOOR DOOR.CFG /5 you can use DOOR DOOR.CFG /%IRQ%
  487.  
  488. (03-19-92)
  489.   DoorFrame is now aware of the PCBoard environment variables %PCBDRIVE% and
  490.  %PCBDIR%. Although it is tranparent to you, the programmer, if it finds
  491.  those two variables on the first line of the .CFG file it will substitute
  492.  the correct drive and path.
  493.   Also fixed a small bug with the time remaining when using USERS.SYS. 
  494.  
  495. Version 1.3
  496. -----------
  497. (03-07-92)
  498.   Fixed a small problem with the high score bulletin. If the bulletin was in
  499.  other than the current directory, the path for the graphics bulletin got
  500.  screwed up.
  501.  
  502.   Added a new variable - Hi.Ascii% which allows you to accept ASCII values
  503.  from 128 to 255. This was added at the request of one of our European users
  504.  since some languages need to use those characters.  Hi.Ascii% = 1 will enable
  505.  this option. The default is zero (disabled).
  506.  
  507. Version 1.2
  508. -----------
  509. (02-23-92)
  510.   One more time on the SEND routine! I was checking the first few characters
  511.  of a file for the CHR$(27) and if found just assumed that the file was all
  512.  ANSI. Not so! Seems there are 'hand-made' files out there that have the
  513.  color codes at the beginning of a line but no where else. So...... redid it
  514.  one more time (hopefully the last!).
  515.  
  516. (02-21-92)
  517.   Optimized the code a bit and moved some routines from the main module to
  518.  the library.  Tested with just a two-line program and the size of the .EXE
  519.  went from 83,034 before optimizing to 72,782 after optimizing.  So that
  520.  should cut down on your file sizes a bit!
  521.  
  522. (02-17-92)
  523.   NOTE: The parameters for the SEND routine have changed with this version!
  524.  The new syntax is SEND FileName$, YN%, Clr%  where Clr% is 0 (home cursor,
  525.  do not clear screen) or 1 (yes, clear screen).
  526.  
  527. Version 1.1
  528. -----------
  529. (02-14-92)
  530.   Added a new routine, ClrEOL. This one will clear to the end of the line.
  531.  You can specify where to start clearing. Example:  ClrEOL 10, 10, 1
  532.  will do it's thing on row 10 and clear from column 10 to the end of the line
  533.  and color it blue. The parameters are Xpos, Ypos, Color. Enjoy!
  534.   Fixed a stupid mistake in the SEND routine. I open CONS: for printing to
  535.  the local screen and misspelled it CON! Funny thing is, it worked except 
  536.  when accessing across a network!
  537.   Added GetDView which returns the version of DESQview loaded or zeroes if
  538.  DESQview is not loaded.
  539.  
  540. (02-10-92)
  541.   Think I finally got that pesky bug in the SEND routine when sending ANSI
  542.  screens fixed! Tested it both local and remote here and it seems to work
  543.  fine. Give it a good workout and let me know if it screws up.
  544.   One quirk I found when using The Draw was when I saved the screen with
  545.  ALT-S it didn't transmit quite right. But when the same screen was saved
  546.  using ALT-B, the screen transmitted perfectly. Go figure! 
  547.  
  548. (02-09-92)
  549.   Had some reports of the Backspace locking systems in local mode in the
  550.  QuickBasic 4.5 version. Did some checking in the routine and the only thing
  551.  I could find that could possibly be the culprit was an IF NOT LocalUsr%
  552.  statement. Since I have had some problems with NOT in the past, I changed
  553.  that statement to IF LocalUsr% = 0. Although I have not had any reports of
  554.  the BASCOM version of DoorFrame locking systems, I made the change just to
  555.  be sure.
  556.   BTW, new BBS number and address with this version.
  557.  
  558. Version 1.0
  559. -----------
  560. (10-25-91)
  561.   Changed the second parameter on the IN.PUT routine from an integer to a
  562.  single precision number. This allows you to specify a waiting time of less
  563.  than 1 second. The minimum wait is now 1/18th of a second (.005 works
  564.  pretty well).
  565.  
  566. (10-21-91)
  567.   Although DoorFrame has an extensive history in the QuickBasic 4.x
  568.  environment, this is the initial release for BASCOM 7.x. The two
  569.  libraries are identical expect for the following routines. 
  570.  
  571.                         FindFirstF        GetDrv
  572.                         FindNextF         GetExecPath
  573.                         GetNameF          GetSub
  574.                         Exists%           GetSub1
  575.                         Exist2%           RInstr
  576.                         SubExist
  577.  
  578.  Most of those routines are available in BASCOM and have become redundant.
  579.  
  580.   The HISTORY file for the Quickbasic 4.x version is included below since those
  581.  changes/fixes/enhancements will usually apply to the BASCOM version. Also,
  582.  there may be some things in here that I neglected to add to DFRAME.DOC.
  583.  
  584.  
  585.  
  586.                           HISTORY FILE FOR DOORFRAME
  587.                           ==========================
  588.  
  589. Version 2.4
  590. -----------
  591. (10-05-91)
  592.   Fixed an oversight in writing the Wildcat! 3.x USERINFO.DAT. Line 16
  593.  (DoorLogoff$) will now show "Y" if the caller logged off from the Door.
  594.  
  595. (09-08-91)
  596.   You may now use the ARROW keys. DoorFrame now has an alternate set of keys
  597.  for the Level and Time adjustments. To switch these keys from the ARROW keys
  598.  to the alternate, use SysopKeys% = 1 AFTER you call INITIALIZE. When you
  599.  have SysopKeys% set to 1, PgUp = add time, PgDn = subtract time, INSert =
  600.  add level, and DELete = subtract level. SysopKeys% defaults to 0 so doors
  601.  compiled with previous versions of DoorFrame will work as before.
  602.   When SysopKeys% = 1 pressing one of the arrow keys will return the
  603.  following in RESPONSE$:
  604.     Up Arrow    - RESPONSE$ = "UP"
  605.     Dn Arrow    - RESPONSE$ = "DOWN"
  606.     Left Arrow  - RESPONSE$ = "LEFT"
  607.     Right Arrow - RESPONSE$ = "RIGHT"
  608.  
  609. (09-06-91)
  610.   Would you believe I left out the code for low-intensity white in the
  611.  DIS.PLAY routine! It has been added. (Thanks to Jerry Claxton for finding
  612.  that one!)
  613.   Added the ability to use low intensity colors when using the symbols in
  614.  the DIS.PLAY routine. To make a color low intensity just put a * in front
  615.  of the first symbol. Ex: *}text} displays 'text' in low intensity white.
  616.  
  617. (08-30-91)
  618.   Changed the EXIT.DOOR "G" routine to allow logoffs on all systems, not just
  619.  PCBoard.
  620.   Changed the WildCat! 3.0 routines so that it DOES NOT automatically write
  621.  the USERINFO.DAT file. If you wish to write this file, set User.Info = 1
  622.  before calling EXIT.DOOR.
  623.  
  624. Version 2.3 
  625. -----------
  626. (06-20-91)
  627.   Added support for WildCat! v3.0. This version of WildCat! no longer uses the
  628.  CALLINFO.BBS file. It now uses the 31-line version of DOOR.SYS and creates an
  629.  additional file called USERINFO.DAT. 
  630.  
  631. (7-07-91)
  632.   They finally woke up at Mustang! Software and are now using the standard
  633.  52-line DOOR.SYS like everyone else. This release adjusts for that. Just put
  634.  the path to USERINFO.DAT on line 1 of the .CFG file (instead of DOOR.SYS).
  635.  Make sure that DOOR.SYS is in the same directory as USERINFO.DAT!
  636.  
  637. Version 2.2
  638. -----------
  639. (03-31-91)
  640.   Added support for non-standard IRQ numbers (other than IRQ3/IRQ4). See the
  641.  docs for info on how to implement this.
  642.  
  643. Version 2.1 (03-23-91)
  644. ----------------------
  645.   Modified the LINES routine. Now if you draw intersecting vertical and
  646.  horizontal lines, the appropriate character will be inserted where the
  647.  lines cross. For example, at the intersection of two double lines the
  648.  character ╬ would be printed.
  649.   Tweaked the MORE routine a little. It was doing a CR/LF after the prompt
  650.  so it wasn't getting erased because it was on the line above!
  651.   Also put in logic in the MORE and ENTER routines to restore the cursor to
  652.  it's position before the call.
  653.   Fixed a problem in DORINFOx.DEF where the Sysop names where being taken
  654.  from DORINFO instead of the configuration file. Also allowed for the fact
  655.  that the RBBS DORINFO has 13 lines instead of 12.
  656.   Still didn't have the DORINFOx.DEF quite right for RBBS. Hopefully it will
  657.  work as it should now (helps when you use the correct LINE INPUT statement).
  658.   One more time on DORINFO to fix the BBSSYS$. Also fixed a problem in
  659.  picking up the correct node number.
  660.  
  661. Version 2.0 (02-02-91)
  662. ----------------------
  663.   Fixed a problem with the backspace when the cursor was in columns 79 or
  664.  80 (it wouldn't).
  665.   Enlarged the PRINT USING in the High Score Bulletin. It will now handle
  666.  scores up to 9,999,999,999.
  667.   Made DoorFrames internal error trapping available for those of you who
  668.  wish to utilize it instead of writing your own. All Basic errors are
  669.  trapped and will be written to DFRAME.ERR upon exiting the door.
  670.   Added support for WWIV's CHAIN.TXT file. DoorFrame both reads and writes
  671.  this file. It is untested as of this writing so watch it!
  672.   Added 2 more parameters to the IN.PUT routine. These are INTEGERS and
  673.  indicate the foreground and background colors for the input.
  674.   Updated the CALLINFO.BBS routine to read the newer 36 line format. It
  675.  will still handle the old 30 line format ok.
  676.   Added a parameter to the SHOW.BLT routine. This is a STRING and is
  677.  either "Y" or "N". The "Y" tells the routine to display the "Do you want
  678.  to see the Bulletin" prompt while "N" will bypass the prompt. If you have
  679.  an option on your door menu to view the bulletin, you would use "N" (why
  680.  ask them again!).
  681.  
  682. Version 1.9 (12-31-90)
  683. ----------------------
  684.   Fixed a bug when using the `, @, {, ^ etc. symbols. If one of these
  685.  symbols was entered at an IN.PUT prompt, the program would go bananas.
  686.   I had inadvertantly left out the ENTER prompt at the end of the SEND
  687.  routine so when someone brought it to my attention I belated added it.
  688.  Now I find that is the way some of you want it! So in order to satisfy
  689.  both camps, I have added a parameter to SEND. The syntax is now:
  690.    SEND (MSG$, YN%)   where YN% is an INTEGER. 0 = don't send the ENTER
  691.  prompt at the end, 1 = yes, use it. 
  692.   Added support for Spitfire's SFDOORS.DAT. DoorFrame both reads and writes
  693.  to this file.
  694.   Added the ability to log off from within the Door. However, this option is
  695.  for PCBoard systems only!
  696.   Added MAKE.BLT.CURRENT routine which posts current scores instead of the
  697.  highest scores attained.
  698.   Fixed a bug in the MAKE.BLT routines. It didn't take kindly to an extension
  699.  being included in the Bulletin filename!
  700.  
  701.                          AND THAT'S IT FOR THIS YEAR!!
  702.  
  703. Version 1.8 (12-16-90)
  704. ----------------------
  705.   Added a few more subroutines for programmer convenience. These routines
  706.  will add some capabilities not found in QuickBasic. Routines added are:
  707.    DelFile, DrvSpace, GetDrv, GetExecPath, GetKbd, GetSub, NameCase,
  708.    RInstr, SetError, SetKbd and SubExist.
  709.   Fixed a problem with the ALLOWEDBYTES# variable (helps if you add it to
  710.  the DFRAME.INC file!).
  711.  
  712. Version 1.7 (12-13-90)
  713. ----------------------
  714.   Added support for PCBoard 14.5's USERS.SYS file! Since the bug reports
  715.  had started slacking off, thought I would introduce a few more 8-).
  716.   Added option for no border (spaces) in the BOX.IT routine.
  717.   Forgot to add an ENTER prompt after the last page in the SEND routine. 
  718.  Fixed now.
  719.   Had some reports of Security Levels higher than 32,767 so the LEVEL
  720.  variable has been changed from an INTEGER (%) to a LONG (&).
  721.   Took the Time Left warnings out. They only messed up the screen! So if 
  722.  you want to warn the caller when time gets low, you should check the
  723.  TIMELEFT% variable and display a message accordingly. 
  724.  
  725. Version 1.6 (12-11-90)
  726. ----------------------
  727.   Fixed a problem in the error handling routines. It will hopefully handle
  728.  errors better now and exit gracefully.
  729.   Fixed the 'keyboard timeout' problem when coming out of Chat mode.
  730.   Fixed another Chat mode problem where the lines on the remote screen
  731.  would overwrite when it reached line 23.
  732.   Optimized the library a bit. Cut about 13K off the size of the .LIB.
  733.   Added a check for DOS version. If the DOS version is less than 3.0 it
  734.  will display an error message and exit (DOS 3.0+ is required because the
  735.  files are opened in SHARED mode).
  736.  
  737. Version 1.5 (11-30-90)
  738. ----------------------
  739.   Finally got the midnight time problem fixed where the caller would get a
  740.  time expired message if he had logged on the BBS before midnight and 
  741.  entered the door after midnight.
  742.   Fixed an error when using DORINFOx.DEF. It worked fine as long as
  743.  DORINFOx.DEF was the only thing there but went screwy if you threw a path
  744.  at it.
  745.   When I added the options for color in the middle of a line of text, I
  746.  inadvertantly disabled the full-line blink. Now fixed.
  747.  
  748. Version 1.4 (11-25-90)
  749. ----------------------
  750.   Added some enhancements to the DIS.PLAY routine. By using special symbols,
  751.  selected text can be displayed in different colors (like BLUE, YELLOW, BLUE)
  752.  without having to use 3 DIS.PLAY statements. See the DOCS and DISPLAY.BAS
  753.  for a complete explanation.
  754.   Added the MODE% variable. Previously if you used DETECT.ANSI, the caller
  755.  would be switched to COLOR MODE automatically. With the MODE% variable, the
  756.  color will be on or off depending on the caller's BBS setting.
  757.   Modified the IN.PUT routine somewhat. It now requires 2 parameters to be
  758.  passed. The first parameter is the desired length of the input and the 
  759.  second is the length of time to wait for that input.
  760.  
  761. Version 1.3 (11-20-90)
  762. ----------------------
  763.   Added a time limit option to the IN.PUT routine. See EXINPUT.BAS for
  764.  and example on using it.
  765.   Fixed an 'oversight' in the OUT.PUT routine. Completely left out updating
  766.  the column position!
  767.   Made a correction in the centering routine. Now when you use centering
  768.  with a colored background, you don't get the colored line all the way
  769.  across the screen! Also, if you do an IN.PUT after a center it will be
  770.  properly positioned after the prompt instead of on the right edge.
  771.  
  772. Version 1.2 (11-17-90)
  773. ----------------------
  774.   Made the Keyboard Timeout configurable by the programmer. Before calling
  775.  INITIALIZE, populate TIMEOUT% with the number of seconds you want for
  776.  input. If you do not specify a TIMEOUT%, it will default to 5 minutes.
  777.  The minimum is 60 secs so anything less than that will be the default.
  778.   Added support for DORINFOx.DEF which now gives us QBBS, RBBS, and
  779.  Remote Access! (Note: This needs to be tested more. Any volunteers?)
  780.  
  781. Version 1.1 (11-12-90)
  782. ----------------------
  783.   Fixed a problem with the cursor positioning routines when the local display
  784.  was toggled off (it didn't work!).
  785.   Changed the BOX subroutine to BOX.IT to avoid a naming conflict with other
  786.  add-on packages for QB 4.5. (Crescent Software's for one).
  787.   Added support for CALLINFO.BBS so your doors will now run on Wildcat! 
  788.  systems without a converter!
  789.  
  790. Version 1.0 (11-1-90)
  791. ---------------------
  792. Initialize release.
  793.  
  794.  
  795.  
  796.